<!DOCTYPE HTML>
<html>
<head>
<title>标签 | AutoHotkey</title>
<meta name="description" content="Labels identify a line of code, and can be used as Goto targets or to form subroutines." />
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<link href="../static/theme.css" rel="stylesheet" type="text/css" />
<script src="../static/content.js" type="text/javascript"></script>
<script type="text/javascript">$(function(){0<=window.navigator.userAgent.toLowerCase().indexOf("ucbrowser")&&CaoNiMaDeUc()})</script>
</head>
<body>

<h1>标签</h1>

<h2 id="toc">目录</h2>
<ul>
  <li><a href="#syntax-and-usage">语法和用法</a></li>
  <li><a href="#subroutines">子程序</a></li>
  <li><a href="#dynamic-labels">动态标签</a></li>
  <li><a href="#hotkeys-and-hotstrings">热键和热字串</a></li>
  <li><a href="#named-loops">命名的循环</a></li>
  <li><a href="#Functions">函数</a></li>
  <li><a href="#related">相关的</a></li>
</ul>

<h2 id="syntax-and-usage">语法和用法</h2>
<p>标签用来标识代码行, 可以作为 <a href="../commands/Goto.htm">Goto</a> 目标或组成<a href="#subroutines">子程序</a>. 标签有三种: 普通的命名标签, <a href="../Hotkeys.htm">热键</a>标签和<a href="../Hotstrings.htm">热字串</a>标签.</p>
<p>普通的标签由名称和冒号组成.</p>
<pre>this_is_a_label:
</pre>
<p>热键标签由热键和双冒号组成.</p>
<pre>^a::
</pre>
<p>热字串标签由冒号, 零个或多个<a href="../Hotstrings.htm#Options">选项</a>, 另一个冒号, 缩写和双冒号组成.</p>
<pre>:*:btw::
</pre>
<p>通常, 除了空白和注释之外, 其他代码不能与标签写在同一行上. 然而:</p>
<ul>
  <li>热键标签可以直接后跟命令或其他语句来创建 <em>单行</em> 热键. 换句话说, 如果命令, 赋值或表达式与热键标签在同一行上, 那么它的作用就像后跟着 <code>return</code> 一样.</li>
  <li>在双冒号右边写有<a href="../KeyList.htm">按键名称</a>的热键实际上是<a href="Remap.htm"><em>重映射</em></a>, 这是<a href="../misc/Remap.htm#actually">一对热键</a>的简写. 例如, <code>a::b</code> 创建 <code>*a</code> 和 <code>*a Up</code> 的热键和标签, 而不创建名为 <code>a</code> 的标签.</li>
  <li>在最后一个双冒号的右侧写有文本的热字串是 <em>自动替换</em> 热字串. 自动替换热字符串不能作为标签.</li>
</ul>
<p><strong>名称:</strong> 标签名不区分大小写, 且可以由除空格, tab, 逗号以及<a href="EscapeChar">转义字符</a>(`) 外的其他字符组成. 然而, 考虑到命名的惯例, 通常最好仅使用字母, 数字和下划线(例如: <em>MyListView</em>, <em>Menu_File_Open</em> 和 <em>outer_loop</em>). 在整个脚本中标签名必须是唯一的.</p>
<p>虽然没有保留的标签名, 但是强烈建议不要使用以下名称: On, Off, Toggle, AltTab, ShiftAltTab, AltTabAndMenu 和 AltTabMenuDismiss. 
这些值对 <a href="../commands/Hotkey.htm">Hotkey 命令</a>有特殊的含义.</p>
<p><strong>目标:</strong> 标签的目标是下一个可执行的代码行. 可执行代码包含命令, 赋值, <a href="../Variables.htm#Expressions">表达式</a>和<a href="../commands/Block.htm">区块</a>, 但不包括指令, 标签, 热键或热字串. 在下面的例子中, <code>run_notepad</code> 和 <code>#n</code> 标签都指向 <code>Run</code> 行:</p>
<pre>run_notepad:
#n::
    Run Notepad
    return
</pre>
<p><strong>执行:</strong> 与指令类似, 正常执行到标签时标签会被忽略. 在下面的例子中, 消息框会显示两次: 一次是在执行 <a href="../commands/Gosub.htm">Gosub</a> 的目标子程序时, 再次是在前面的子程序返回后:</p>
<pre>gosub Label1

Label1:
MsgBox <a href="../Variables.htm#ThisLabel">%A_ThisLabel%</a>
return</pre>

<h2 id="subroutines">子程序</h2>
<p>子程序是一部分代码, 可以对它进行 <em>调用</em> 来执行特定的任务. 子程序的执行从目标标签开始, 一直执行到遇上 <a href="../commands/Return.htm">Return</a> 或 <a href="../commands/Exit.htm">Exit</a>. 由于子程序的结尾决定于流控制, 所以任何标签既作为 Goto 的目标同时也是子程序的开始.</p>

<h2 id="dynamic-labels">动态标签</h2>
<p>接受标签名的许多命令也可以接受<a href="../Variables.htm">变量</a>引用(例如 %MyLabel%), 此时变量中保存了目标标签的名称. 然而, 性能会稍微降低, 因为每次都必须 "查找" 目标标签名而不是只在脚本首次加载时查找一次.</p>

<h2 id="hotkeys-and-hotstrings">热键和热字串</h2>
<p>每个<a href="../Hotkeys.htm">双冒号热键</a>也会创建一个标签, 除非它是一个<a href="../Hotkeys.htm#Function">函数热键</a>. 标签的名称和脚本中的名称完全相同, 并且可以和 <a href="../Variables.htm#ThisHotkey">A_ThisHotkey</a> 报告的热键名称不同, 比如说修饰符以不同的顺序写. 标签名称包括热键的修饰符, 但不包括最后的双冒号(<code>::</code>).</p>
<p><a href="../Hotstrings.htm#label">热字串标签</a>的名称包括前面的冒号和选项, 但不包括最后的双冒号(<code>::</code>).</p>
<p><a href="../Hotkeys.htm">热键</a>和<a href="../Hotstrings.htm#label">热字串标签</a>也可以作为<a href="../commands/Goto.htm">Goto</a>, <a href="../commands/Gosub.htm">Gosub</a> 以及其他命令的有效目标. 然而, 一个热键或热串标签只有在它是给定名称的第一个标签时才能以这种方式使用. 例如:</p>
<pre>gosub ^+a  <em>; 示例热键.</em>
gosub +^a  <em>; 全局热键.</em>
gosub Esc  <em>; Esc 标签.</em>
ExitApp

#IfWinActive Example
^+a::MsgBox Example hotkey.
Esc:
    MsgBox Esc label.
    return
#If
+^a::MsgBox Global hotkey.
Esc::MsgBox Esc hotkey.</pre>
<p>这个限制也适用于 <a href="../commands/Hotkey.htm">Hotkey</a> 命令的 <em>Label</em> 参数.</p>

<h2 id="named-loops">命名的循环</h2>
<p>标签还可以用来标识循环, 以便用于 <a href="../commands/Continue.htm">Continue</a> 和 <a href="../commands/Break.htm">Break</a> 命令. 这样脚本可以很方便地继续或退出任意数目的内嵌循环.</p>

<h2 id="Functions">函数</h2>
<p><span class="ver">[v1.1.20+]</span>: <a href="../Functions.htm">函数</a>可以在多种情况下替代原来的标签, 包括:</p>
<ul>
  <li><a href="../commands/Gui.htm#Labels">Gui 事件</a>(例如 GuiClose)</li>
  <li><a href="../commands/Gui.htm#label">Gui 控件事件</a>(g-标签)</li>
  <li><a href="../commands/Hotkey.htm#Functor">热键</a></li>
  <li><a href="../commands/Menu.htm#Functor">菜单</a></li>
  <li><a href="../commands/SetTimer.htm#Functor">SetTimer</a></li>
</ul>
<p></p>
<p>函数的好处是它们可以使用局部变量, 在某些情况下(比如 GUI 控件事件), 它们也接受包含有用信息的参数.</p>

<h2 id="related">相关</h2>
<p><a href="../commands/IsLabel.htm">IsLabel()</a>, <a href="../Variables.htm#ThisLabel">A_ThisLabel</a>, <a href="../commands/Gosub.htm">Gosub</a>, <a href="../commands/Goto.htm">Goto</a>, <a href="../commands/OnExit.htm#command">OnExit</a>, <a href="../commands/SetTimer.htm">SetTimer</a>, <a href="../commands/Hotkey.htm">Hotkey</a>, <a href="../commands/Gui.htm#Labels">Gui 事件</a>, <a href="../commands/Gui.htm#label">g-标签</a>, <a href="../commands/OnClipboardChange.htm#label">OnClipboardChange 标签</a></p>

</body>
</html>